﻿<!DOCTYPE html>
<html>
<head>
    <meta charset="utf-8">
    <meta http-equiv="X-UA-Compatible" content="IE=edge">
    <title>员工管理</title>
    <#include "/common/link.ftl">
    <script>

        //实现左移右移的功能
        function moveSelected(src, target) {
            $("." + target).append($("." + src + " > option:selected"));
        }

        //实现全左全右的功能
        function moveAll(src, target) {
            $("." + target).append($("." + src + " > option"));
        }


        $(function () {
            //对超管做判断
            let roleDiv;
            $("#admin").click(function () {
                //获取当前复选框的状态
                $checked = $(this).prop("checked");
                if ($checked) {
                    roleDiv = $("#roleDiv").detach();
                } else {//没有选中，恢复角色权限
                    $("#adminDiv").after(roleDiv);
                }
            })
            //页面加载完成后判断
            let $checked = $("#admin").prop("checked");
            if ($checked) {
                roleDiv = $("#roleDiv").detach();
            }

            //保存，将数据添加
            $(".btn-submit").click(function () {
                //直接提交表单
                $(".selfRoles > option").prop('selected', true);
                $('#editForm').submit();
            })
        })

        $(function () {
            let ids = [];
            //去除重复的操作
            //1. 将右边下拉框<select multiple class="form-control selfRoles" size="15" name="ids">中的取出来
            $(".selfRoles > option").each(function (index, ele) {
                ids.push($(ele).val());
            })
            //2.将左边下拉框的值与放到数组中的值比较，若相同的话直接从左边下拉框中删除
            $(".allRoles > option").each(function (index, ele) {
                let id = $(ele).val();
                if ($.inArray(id, ids) >= 0) {
                    $(ele).remove();
                }
            })
        })
    </script>

</head>
<body class="hold-transition skin-black sidebar-mini">
<div class="wrapper">
    <#include "/common/navbar.ftl">
    <!--菜单回显-->
    <#assign currentMenu="employee"/>
    <#include "/common/menu.ftl">
    <div class="content-wrapper">
        <section class="content-header">
            <h1>员工编辑</h1>
        </section>
        <section class="content">
            <div class="box">
                <form class="form-horizontal" action="/emp/saveOrUpdate" method="post" id="editForm">
                    <input type="hidden" name="id" value="${emp.id}">
                    <div class="form-group" style="margin-top: 10px;">
                        <label class="col-sm-2 control-label">用户名：</label>
                        <div class="col-sm-6">
                            <input value="${emp.username}" type="text" class="form-control" name="username"
                                    <#--修改时用户名应该只读-->
                                    <#if emp ??>
                                        disabled
                                    </#if>
                                   placeholder="请输入用户名">
                        </div>
                    </div>
                    <div class="form-group" style="margin-top: 10px;">
                        <label class="col-sm-2 control-label">真实姓名：</label>
                        <div class="col-sm-6">
                            <input value="${emp.name}" type="text" class="form-control" name="name"
                                   placeholder="请输入真实姓名">
                        </div>
                    </div>
                    <#--若密码没有值，是新增，才显示-->
                    <#if !emp??>
                        <div class="form-group">
                            <label for="password" class="col-sm-2 control-label">密码：</label>
                            <div class="col-sm-6">
                                <input type="password" class="form-control" id="password" name="password"
                                       placeholder="请输入密码">
                            </div>
                        </div>
                        <div class="form-group">
                            <label for="repassword" class="col-sm-2 control-label">验证密码：</label>
                            <div class="col-sm-6">
                                <input type="password" class="form-control" id="repassword" name="repassword"
                                       placeholder="再输入一遍密码">
                            </div>
                        </div>
                    </#if>
                    <div class="form-group">
                        <label for="email" class="col-sm-2 control-label">电子邮箱：</label>
                        <div class="col-sm-6">
                            <input value="${emp.email}" type="text" class="form-control" name="email"
                                   placeholder="请输入邮箱">
                        </div>
                    </div>
                    <div class="form-group">
                        <label for="age" class="col-sm-2 control-label">年龄：</label>
                        <div class="col-sm-6">
                            <input type="text" value="${emp.age}" class="form-control" name="age" placeholder="请输入年龄">
                        </div>
                    </div>
                    <div class="form-group">
                        <label for="dept" class="col-sm-2 control-label">部门：</label>
                        <div class="col-sm-6">
                            <select class="form-control" id="dept" name="deptId">
                                <option value="">全部</option>
                                <#list departments as department>
                                <#--<#if (department.id=emp.deptId)>selected="selected"</#if> -->
                                    <option value="${department.id}">${department.name}</option>
                                </#list>
                            </select>
                            <script>
                                $("#dept").val(${emp.deptId});
                            </script>
                        </div>
                    </div>
                    <div class="form-group" id="adminDiv">
                        <label for="admin" class="col-sm-2 control-label">超级管理员：</label>
                        <div class="col-sm-6" style="margin-left: 15px;">
                            <input type="checkbox"  id="admin"<#--emp.admin!false-->
                                   name="admin" class="checkbox" ${(emp!=null &&emp.admin) ? string('checked','')}>
                        </div>
                    </div>
                    <div class="form-group" id="roleDiv">
                        <label for="role" class="col-sm-2 control-label">分配角色：</label><br/>
                        <div class="row" style="margin-top: 10px">
                            <div class="col-sm-2 col-sm-offset-2">
                                <select multiple class="form-control allRoles" size="15">
                                    <#list roles as role>
                                        <option value="${role.id}">${role.name}</option>
                                    </#list>
                                </select>
                            </div>

                            <div class="col-sm-1" style="margin-top: 60px;" align="center">
                                <div>

                                    <a type="button" class="btn btn-primary  " style="margin-top: 10px" title="右移动"
                                       onclick="moveSelected('allRoles', 'selfRoles')">
                                        <span class="glyphicon glyphicon-menu-right"></span>
                                    </a>
                                </div>
                                <div>
                                    <a type="button" class="btn btn-primary " style="margin-top: 10px" title="左移动"
                                       onclick="moveSelected('selfRoles', 'allRoles')">
                                        <span class="glyphicon glyphicon-menu-left"></span>
                                    </a>
                                </div>
                                <div>
                                    <a type="button" class="btn btn-primary " style="margin-top: 10px" title="全右移动"
                                       onclick="moveAll('allRoles', 'selfRoles')">
                                        <span class="glyphicon glyphicon-forward"></span>
                                    </a>
                                </div>
                                <div>
                                    <a type="button" class="btn btn-primary " style="margin-top: 10px" title="全左移动"
                                       onclick="moveAll('selfRoles', 'allRoles')">
                                        <span class="glyphicon glyphicon-backward"></span>
                                    </a>
                                </div>
                            </div>

                            <div class="col-sm-2">
                                <select multiple class="form-control selfRoles" size="15" name="ids">
                                    <#--右边下拉框的角色权限数据回显-->
                                    <#list emp.roles as role>
                                        <option value="${role.id}">${role.name}</option>
                                    </#list>
                                </select>
                            </div>
                        </div>
                    </div>

                    <div class="form-group">
                        <div class="col-sm-offset-1 col-sm-6">
                            <button type="button" class="btn btn-primary btn-submit">保存</button>
                            <a href="javascript:window.history.back()" class="btn btn-danger">取消</a>
                        </div>
                    </div>

                </form>

            </div>
        </section>
    </div>
    <#include "/common/footer.ftl">

</div>
<script>
    $("#editForm").bootstrapValidator({
        fields:{
            username:{ //input 中的name对应的值
                validators:{ //不能为空 ,并且长度是2-8个字符串
                    notEmpty:{
                        message:'用户名不能为空'
                    },
                    stringLength:{//字符长度
                        min:2,
                        max:8,
                        message:"输入2-8个字符"
                    },
                    remote: { //远程验证
                        type: 'POST', //请求方式
                        url: '/emp/checkUsername', //请求地址
                        message: '用户名已经存在', //验证不通过时的提示信息
                        delay: 2000 //输入内容2秒后发请求
                    }
                }
            },
            name: {
                validators: {
                    notEmpty: {
                        message: '账号不能为空'
                    }
                }
            },
            password:{
                validators: {
                    notEmpty: {
                        message: '密码不能为空'
                    }
                }
            },
            repassword:{
                validators: {
                    notEmpty: {
                        message: '确认码不能为空'
                    },
                    identical: {
                        field: 'password',
                        message: '密码要和确认码相同'
                    }
                }
            },
            email:{
                validators: {
                    emailAddress: {
                        message: '邮箱不能为空'
                    }
                }
            },
            age:{
                validators: {
                    between: { //数字的范围
                        min: 0,
                        max: 100
                    }
                }
            }

        }
    }).on('success.form.bv', function() { //表单所有数据验证通过后执行里面的代码
        //提交异步表单
        $("#editForm").ajaxSubmit(function (data) {
            if(data.success){
                Swal.fire({
                    // text: data.msg,
                    text:'保存成功',
                    icon: 'success',
                    confirmButtonColor: '#3085d6',
                    cancelButtonColor: '#d33',
                    confirmButtonText: '保存成功'
                }).then((result) =>{
                    window.location.href = '/emp/list';
                })
            }else {
                Swal.fire(
                    data.msg,
                    '',
                    'error'
                )
            }
        })
    });
</script>
</body>
</html>
